package cn.zqy.demo2.day04.demo02;

import java.util.HashMap;
import java.util.Scanner;

/*
*练习:
        计算一个字符串中每个字符出现次数

    分析:
        1.使用Scanner获取用户输入的字符串
        2.创建Map集合,key是字符串中的字符,value是字符的个数
        3.遍历字符串,获取每一个字符
        4.使用获取到的字符,去Map集合判断key是否存在
            key存在:
                通过字符(key),获取value(字符个数)
                value++
                put(key,value)把新的value存储到Map集合中
            key不存在:
                put(key,1)
        5.遍历Map集合,输出结果
* */
public class Demo04MapTest {
    public static void main(String[] args) {
        /*1.使用Scanner获取用户输入的字符串*/
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入字符串：");
        String next = sc.next();

       /* 2.创建Map集合,key是字符串中的字符,value是字符的个数*/
        HashMap<Character, Integer> map = new HashMap<>();
        /* 3.遍历字符串,获取每一个字符*/
        for (Character i: next.toCharArray()) {

            /*法一：使用get的返回值判断*/
            Integer kk = map.get(i);
            if (kk == null) {
                map.put(i, 1);
            } else {
                Integer num = map.get(i);
                map.put(i, ++num);
            }

            // ###法二： 使用containsKey(key)返回值判断
           /* boolean b = map.containsKey(i);
            if (b) {
                Integer num = map.get(i);
                map.put(i, ++num);
            } else {
                map.put(i, 1);
            }*/



        }
        System.out.println(map);
    }
}
